如果讀者有寫過程式,想必大家對於函式都不陌生。
除非你把邏輯都寫在
main()
啦,那就另當別論了 XDDD
函式 (function) 是執行特定工作的敘述集合,它的主要功能如下:
將程式碼中的重複邏輯抽取出來,使程式碼更簡潔。
原始程式碼:
let a = 1 + 3;
let b = a + 2;
let c = a + b;
let d = c + 1;
使用函式後:
sum(para1, para2){
return para1 + para2;
}
let a = sum(1,3); // 1 + 3 = 4
let b = sum(a,2); // 4 + 2 = 6
當程式碼非常龐大時,可以依據不同的功能將程式碼分成好幾個片段,讓程式碼結構化以方便管理。
在瞭解函式的定義以及用途以後,我們一起來學習如何宣告函式吧!
原始作法
我們將函式宣告以後沒有賦予它名字,便直接將其存放在 sum
變數中,這類函式又稱為匿名函式。
let sum = function(para1, para2){
return para1 + para2;
}
sum(1,2); //3
當然,如果你希望它也有屬於自己的名字,也可以考慮這樣做:
let sum = function myName(para1, para2){
return para1 + para2;
}
注意 ! myName 這個名字只有在函式本身內有效,跳脫該函式的範圍後就沒有人認識他了 !
let sum = function myName(para1, para2){
console.log(myName); //valid
return para1 + para2;
}
console.log(sum) //valid
console.log(myName) //invalid
簡潔作法
function sum(para1, para2){
return para1 + para2;
}
sum(1,2); //3
使用 new Function
建構函式
new Function (arg1, arg2, ... argN, functionBody)
-- MDN web docs
如果利用該方法去建構函式,先前的範例會變成:
let sum = new Function ('para1', 'para2', 'return para1 + para2');
筆者並不建議利用這個方式去宣告函式,因為該作法會讓編譯器需要花費多餘的性能去解析字串。
物件函式縮寫
一般情況,若我們需要在物件內宣告函式會需要這麼做:
let obj = {
sum: function(para1, para2){
return para1 + para2;
}
};
JavaScript ES2015 (ES6) 提供給我們更簡潔的作法:
如果讀者對於 ES2015, ES2020... 等常見字眼感到疑惑,可以參考今天的延伸閱讀唷 !
let obj = {
sum(para1, para2){
return para1 + para2;
}
};
懶人包: 定義完就執行的函式。
一般情況下,函式被定義後還需要被呼叫才會執行。不過,在 JavaScript 中有個特別的存在可以允許函式被定義後就立即執行。
下面範例為一般的函式,定義後需要呼叫才會將結果回傳。
function sum(para1, para2){
return para1 + para2;
}
let result = sum(1,2); //3
而 IIFE 比較特別,並不需要呼叫:
let result = function sum(para1, para2){
return para1 + para2;
}(1,2)
如果今天筆者不打算使用變數存放函式的結果,而是希望利用 IIFE 去做程式碼的初始化設定,可以這麼做:
(funtion init(){
console.log("Init!")
})()
或是利用 void
達到同樣的目的:
void funtion init(){
console.log("Init!")
}()
知識點: void
請參考延伸閱讀。
記住,當函式被宣告為立即函式後,便無法利用一般的方式呼叫它:
init()
錯誤代碼:
Uncaught ReferenceError: init is not defined
同樣的事情在不同人眼中可能會有不同的見解、看法。
在讀完本篇以後,筆者也強烈建議大家去看看以下文章,或許會對型別、變數宣告...等觀念有更深層的看法唷!
六角學院共同創辦人 - 卡斯柏 大大的部落格也是學習前端技術的必讀網站,筆者學習相關知識時經常能夠在該網站獲得解答。因此,在這邊推薦給各位讀者。